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What is claimed is: 

1. A method of managing retrieval of messages from/k 
queue, each message on the queue having been sent 25y a 
sender application program, the method comprising: 

assigning an index key to a message in response to 
commit of the operation of putting the message on the 
queue, wherein the assigned index key comprises an 
attribute value of the message which wafe specified by the 
sending application when the message /was sent; and 

in response to a receiver appl/lcation program 
requesting retrieval of messages /from the queue and 
specifying the attribute value ^monitoring the availability 
of messages in the queue with/reference to said assigned 
index key, whereby the index, key assigned to the message in 
response to said commit provides an index which is usable 
for identifying committed messages having the particular 
application-specified' attribute value. 

2. A method according to claim 1, including: 

in response to the monitoring step identifying the 
availability pt a committed message in the queue which has 
the assignee? index key, determining whether the message 
matches omer criteria of the retrieval request; and 
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in response to a positive match, sending a response \ £o 
the application program which issued the request. / 

3. A method according to claim 2, wherein the response 
includes the message which matches the request. / 

4. A method according to claim 1, wherein/the attribute 
value included in the assigned index keyyr a message 
identifier or a correlation identifier./ 

5. A method according to claim 1, /wherein receiver 
application programs are able to ifesue retrieval requests 
with a wait attribute, and wherein the method includes: 

responsive to no messages' which match the request 
being available in the queuer when the request is issued, 
triggering a monitoring process to perform the monitoring 
step; and / 

responsive to the monitoring step identifying the 
availability of a committed message in the queue having 
said assigned index key, determining whether the message 
matches a waiting retrieval request and, if matching, 
sending a response to the application program which issued 
the request/ 
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6. A method according to claim 1, wherein the queue yd a 
shared access queue held in a list structure of a Coupling 
Facility to which a plurality of resource managers/can 
connect to put messages on the queue and to retrieve 
messages from the queue on behalf of respective sender and 
receiver application programs. / 

7. A method according to claim 6, wherein the step of 
assigning an index key at commit time/comprises a resource 
manager which put the message on the shared queue providing 
the attribute value to the Coupling Facility in response to 
committing the put operation, the Coupling Facility then 
building the index key and storing it in association with 
the enqueued message. / 

8. A method according/to claim 6, wherein the assigned 
index value for each passage is held in a predefined 
control data area oy the Coupling Facility list structure 
which holds the queue . 

9. A method Recording to claim 8, wherein the predefined 
control data/area of the Coupling Facility list structure 
is a Coupl/ng Facility list entry control data area, and 
the predefined control data area holds a message identifier 
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and a correlation identifier for the message, the assigned 
index key comprising one of said message identifier or 
correlation identifier. 

5 10. A method according to claim 6, wherein/the monitoring 

step is performed by a monitoring process^ within the 
Coupling Facility in response to receipt of a retrieval 
re q U est which specifies said attrib^fe value, the 
monitoring process including: 
10 means for determining whether an identified available 

message matches all criteria fft the received retrieval 
request; and 

means, responsive to/a positive match, for sending a 
response to the applica^on program which issued the 
\S request. 

H 11. A method according to claim 10, wherein the monitoring 

fU process is adapted/ to invoke said means for determining a 

□ match for all identified messages in said queue which have 

^ said assigned i^ndex value corresponding to the 

20 application-specified attribute value. 
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12. A method according to claim 1, wherein the assigned 
key comprises a secondary index key representing a 
sende^-application-assigned attribute and can be used to 
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identify messages in response to a retrieval request wjarlch 
specifies said attribute, and an additional primary/index 
key comprising sequencing information is assignejrto a 
message when the message is placed on the queue; and 
wherein the primary index key is used to select a message 
for retrieval from the available messaged identified in the 
monitoring step which used the secondary key. 

13 . A program product comprising^ program code including 
executable program instructions' recorded on a 
machine -readable recording medium, for controlling the 
performance of operations j6f a data processing apparatus on 
which it executes, the program code including: 

program code for /assigning an index key to a message 
in response to commi^t of the operation of putting the 
message on the que{ie, wherein the assigned index key 
comprises an attribute value of the message which was 
specified by t'he sending application when the message was 
sent ; and / 

program code, responsive to a receiver application 
program/requesting retrieval of messages from the queue and 
specifying the attribute value, for monitoring the 
availability of messages in the queue with reference to 
sadd assigned index key, whereby the index key assigned to 
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the message in response to said commit provides an incjfex 
which is usable for identifying committed messages tfeving 
the particular application-specified attribute va/ue, 

14 . A program product according to claim 13^/wherein the 
program code includes 

means, responsive to the monitorinq/step identifying 
the availability of a committed message in the queue which 
has the assigned index key, for determining whether the 
message matches other criteria of/the retrieval request; 
and 

means, responsive to a p6sitive match, for sending a 
response to the applicatioj/ program which issued the 
request . 

15. A resource manager component for a data processing 
apparatus, for starring messages within a queue and storing 
index keys in association with the enqueued messages for 
use in retrieval of the messages from the queue, the 
resource manager component including: 

means for assigning an index key to a message in 
respons^to commit of the operation of putting the message 
on the queue, wherein the assigned index key comprises an 
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attribute value of the message which was specified by/the 
sending application when the message was sent; and / 

means, responsive to a receiver applicatioryprogram 
requesting retrieval of messages from the queu/ and 
specifying the attribute value, for monitoring the 
availability of messages in the queue with/reference to 
said assigned index key, whereby the indfex key assigned to 
the message in response to said commit/ provides an index 
which is usable for identifying committed messages having 
the particular application-specified attribute value. 

16. A data processing apparatus including: 
storage means; / 
a data processor; / 

a resource manager ^component for storing messages 
within a queue and storing index keys in association with 
the enqueued message/ for use in retrieval of the messages 
from the queue, th£ resource manager component including: 

means for assigning an index key to a message in 
response to copfimit of the operation of putting the message 
on the queue/ wherein the assigned index key comprises an 
attribute /alue of the message which was specified by the 
sending application when the message was sent; and 
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means, responsive to a receiver application proq^am 
requesting retrieval of messages from the queue anjT 
specifying the attribute value, for monitoring bfte 
availability of messages in the queue with reference to 
said assigned index key, whereby the index/key assigned to 
the message in response to said commit provides an index 
which is usable for identifying committed messages having 
the particular application- specified attribute value. 

17. A data processing apparatus according to claim 16, 
wherein the resource manager component includes means, 
responsive to the monitoring step identifying the 
availability of a admitted message in the queue which has 
the assigned ind£x key, for determining whether the message 
matches other/criteria of the retrieval request, and the 
apparatus further includes means, responsive to a positive 
match, for sending a response to the application program 
which/issued the request. 



